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Abstract. Given a graph G = (V, E) and a set of terminal vertices T we 
say that a superset S of T is T-connecting if S induces a connected graph, 
and S is minimal if no strict subset of S is T-connecting. In this paper 
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we prove that there are at most ( T i_<j) • 3 3 minimal T-connecting 
sets when |T| < n/3 and that these can be enumerated within a polyno- 
mial factor of this bound. This generalizes the algorithm for enumerating 
all induced paths between a pair of vertices, corresponding to the case 
T| = 2. We apply our enumeration algorithm to solve the 2-Disjoint 
Connected Subgraphs problem in time O* (1.7804"), improving on the 
recent O* (1.933™) algorithm of Cygan et al. 2012 LATIN paper. 

1 Introduction 

The listing of all inclusion minimal combinatorial objects satisfying a cer- 
tain property is a standard approach to solving certain A^P-hard prob- 
lems exactly. Some examples are the algorithms for Minimum Dominat- 
ing Set in time 0*(1.7159 n ) [3], for Feedback Vertex Set in time 
0*(1.7548 n ) [2J, and for Minimal Separators in time 0*(1.6181) @]. 
At the time of their appearance these algorithms were the fastest ones 
available. 

This is an approach that usually requires little in the way of correct- 
ness arguments. For example, in the minimum dominating set problem 
it is obvious that a dominating set of minimum cardinality is also an 
inclusion minimal dominating set. The main task in this approach is to 
firstly enumerate the inclusion minimal objects, preferably by an algo- 
rithm whose runtime is within a polynomial factor of the number of such 
objects, and secondly to provide a good upper bound on the number of 
objects. Probably the most famous example is the polynomial delay enu- 
meration algorithm for Maximal independent set [7| where there are 
matching upper and lower bounds on the number of objects [8J. 

Another case with matching upper and lower bounds is the 0*(33) 
folklore algorithm enumerating all induced paths between two fixed ver- 



tices u and v in an n- vertex graphj In this paper we consider some gen- 
eralizations of this graph problem. We first generalize to the enumeration 
of induced paths starting in v and ending in a vertex from a given set 
R, with no intermediate vertices in N(R). The algorithm we give for this 
generalization will be optimal, up to polynomial factors. Given a subset of 
vertices T let us say that a superset S of T is T-connecting if S induces a 
connected graph, and that S is minimal T-connecting if no strict subset of 
S is T-connecting. Our main generalization is the following enumeration 
task: 

Enumeration of Minimal T-Connecting Sets 
Input: A graph G = (V, E) and a set T C V. 
Output: All minimal T-connecting sets. 

Note that for the case |T| = 2 the minimal T-connecting sets are in 1-1 
correspondence with the set of induced paths between the two vertices of 
T. We give an algorithm for Enumeration of Minimal T-Connecting 

Sets with runtime 0*((mJ5J) ■ 3 ! ^) where |T| < n/3. For |T| > n/3 

a trivial 0*(2 n_ ' T ') brute force enumeration can be used. We apply this 
enumeration algorithm to solve the following problem: 

2-Disjoint Connected Subgraphs 

Input: A connected graph G = (V, E) and two disjoint subsets of 
terminal vertices Z\ : Z 2 C V . 

Question: Does there exist a partition Ax, A 2 of V, with 
Zi C Ai, Z 2 C A 2 and G[Ax], G[A 2 ] both connected? 

The general version of this problem with an arbitrary number of sets 
was used as one of the tools in the result of Robertson and Seymour 
showing that Minor containment can be solved in polynomial time 
for every fixed pattern graph H |11| . We require the input graph to be 
connected since otherwise it is easy to reduce the problem to a connected 
component. 

Let us look at some previous work on this problem. Motivated by 
an application in computational geometry, Gray et al [6j showed that 
2-Disjoint Connected Subgraphs is NP-complete on planar graphs, 
van't Hof et al [12] showed that on general graphs it is NP-complete 
even when \Z\\ = 2 and also that it remains NP-complete on TV free 

1 We have not been able to find a proof of this algorithm in the literature. The graph 
in Figure 1, with \R\ = 1, shows optimality of the algorithm, up to polynomial 
factors. 



graphs but is polynomial-time solvable on i-Vfree graphs. Notice that 
the naive brute-force algorithm that tries all 2-partitions of non-terminal 
vertices runs in time 0(2 k n°^), where k = n — \Z\ U Z^\. This shows 
that 2-Disjoint Connected Subgraphs is fixed-parameter tractable 
when parameterizing by the number of non-terminals. However, Cygan 
et al m show that breaking this 0*(2 k ) barrier for the number k of non- 
terminals would contradict the Strong Exponential Time Hypothesis, and 
that a polynomial kernel for this parameterization would imply NP C 
coNP/poly. Paulusma and van Rooij |10| gave an algorithm with runtime 
O*(1.2051 n ) for i-6-free graphs and asked whether it was possible to solve 
the problem in general graphs faster than 0(2 n n ^). This question was 
recently answered affirmatively by Cygan et al p] who gave an algorithm 
for 2-Disjoint Connected Subgraphs on general graphs, based on 
the branch and reduce technique, with runtime 0*(1.933 n ). 

Our algorithm for 2-Disjoint Connected Subgraphs on general 
graphs will be based on Enumeration of Minimal T-Connecting 
Sets and have runtime O*(1.7804 n ). 

Our paper is organized as follows. In Section 2 we give the main defini- 
tions. In Section 3 we address the enumeration of induced paths starting 
in v and ending in a vertex from a given set R, with no intermediate 
vertices in R. In Section 4 we give an algorithm for Enumeration of 
Minimal T-Connecting Sets. In Section 5 we apply this enumeration 
algorithm to solve the 2-Disjoint Connected Subgraphs problem. 
We end in Section 6 with some questions. 

2 Definitions 

We deal with simple undirected graphs and use standard terminology. For 
a graph G = (V, E) and S C V we denote by G[S] the graph induced by 
S. An induced subgraph G[S] for S C V is called connected if any pair 
of vertices of S are connected by a path in G[S]. We may also denote the 
vertex set of a graph G by V(G). We denote by N[S] the set of vertices 
that are in S or have a neighbor in S, and let N(S) = N[S] \ S. 

A path P of a graph G is a sequence of vertices (vi, v%, . . . , v q ) such 
that VjVj + i G E for 1 < j < q, and the path is called induced if 
G[{vi, V2, ■ ■ ■ , v q }] has no other edges. A subpath of P is of the form 

«2j • • • > v i) f° r some i < q. 

Contracting an edge uv into vertex v in a graph G is defined as the 
operation of adding, for every vertex w G N(u) \ N[v], the edge vw to G 
if it is not already present, and then deleting u and all edges incident to 



u. Notice that a graph is connected after the contraction operation if and 
only if it was connected before the contraction operation. 

Given a graph G = (V, E), a vertex set T C V, a vertex v\ G V \ T, 
and an induced path P = (vi, i?2, v q ) in G[V\T], we define the branch 
depth of path P to be 

b(P) = \N[{v 1 ,V 2 ,...,V q - 1 }]\-l. 

3 Induced paths from a vertex to a set of vertices 

It is folklore knowledge that the set of induced paths between a pair of 
vertices in an n-vertex graph can be enumerated in 0*(3s) time. We 
have not been able to find a written proof of this in the literature. In 
the following theorem the induced paths between a pair of vertices is a 
special case, thus providing a generalization of a well known result. 

Theorem 1. Given a graph G = (V,E), a vertex v £ V and R C V \ 
N[v], we can enumerate all induced paths from v to a vertex of N(R), 

\V\R\ 

with no intermediate vertex in N[R], in time 0*(3 s ). 




Fig. 1. The number of induced paths between vertex v and a vertex of N(R) (the 

n-\R\-l 

rightmost column of 3 vertices) is 3 3 . Since each such path P has branch depth 
b(P) = n— \R\ — 1 this graph shows tightness of Lemma [5] when b(P) is a multiple of 3. 
If b(P) = 3i + 1 then replace one column of 3 vertices by 4 vertices and if b(P) — 3i + 2 
add a new column of 2 vertices. R induces a connected graph so the number of minimal 

n—\R\—l 

R U {w}-connecting sets is also 3 3 

We actually want the paths from v to R, but since these paths must 
have the second-todast vertex in N(R) we state the result as above. Theo- 
rem [T] will follow from Lemma [2j which is stated in terms of branch depth 
of paths in order to be used for the branching algorithm in the next sec- 
tion. Since the branch depth of each induced path from v to N(R), with 
no intermediate vertex in N(R), is at most \V \R\ — 1, Theorem [T] will 
follow from Lemma [2] below and is tight up to polynomial factors, see 
Figure 1. We start with a combinatorial lemma. 



Lemma 1. Fix a non-negative integer t and let T be a rooted tree where 
any root-to-leaf path v±,V2, ...,v q has £i<i< q c(vi) < t, with c(v) the num- 
ber of children of node v. The maximum number of leaves that T can have 
is l(t) with 1(1) = 1 and for t ^ 1 

'3 i ift = 3i, 
l(t) = ! 4-3 i-1 ift = 3i + l, 
2-3 i ift = 3i + 2. 

Proof. We first show that for any t there is a tree Ut achieving the maxi- 
mum, where all nodes at the same level have the same number of children. 
For any t let Tt be any rooted tree achieving the maximum. Define r(t) as 
the number of children of the root of Tt. In the tree Ut all nodes at level 

1 > 1 will have u(i) children, with u(i) defined level-by-level as follows. 
The root of Ut will have the same number of children as the root of Tt, in 
other words we define u(l) = r(t). The sum of the number of children of 
nodes on any path from a child of the root of Ut to a leaf of Ut should be 
t — u(l), thus nodes at level 2 of Ut should have the same number of chil- 
dren as the root of 2t_ n (i), in other words we define u(2) = r(t — u(l)). 
Continuing like this we get that in general u(i) = r(t — 27i<j<j u(j)). 
By induction on t it follows that Ut has as many leaves as Tt and any 
root-to-leaf path has t children. 

Assume Ut has p levels. We then have that u(l)+u(2)+...+u(p—l) = t 
and that u(l) -u(2)... -u(p — 1), the number of leaves of Ut, is maximized. 
Since the product of these integers is maximized we can assume that we 
have no integer x > 4 among them since then we could replace x by 

2 • (x — 2) > x which does not decrease the product nor changes the sum 
of the integers. Also, if 2 appears then it appears at most twice since we 
could replace 2-2-2 by 3-3>2-2-2. This implies that the number of 
leaves in Ut is l(t) as stated in the Lemma. 

Note that l(t) is the maximum number of maximal independent sets 
in a graph on t vertices |8|5j . For the connection to the largest integer 
which is the product of positive integers with sum t see e.g. |13j . 



Lemma 2. Given a graph G = (V,E), a vertex v\ € V, R C V \ 
N\v\], and an integer t. Then there exist at most l(t) induced paths 
P = (v\,V2, v q ) in G such that 

b(P) < t, 
- Vi £ N[R] for 1 < i < q — 1, and 
-v q e N(R). 



Furthermore all these paths can be enumerated in 0*(3a) time. 

Proof. The enumeration algorithm will be a standard backtracking algo- 
rithm starting in v\ that checks all choices. At the first step the choices 
for V2 are the vertices in N(v\). In general, when we have a subpath 
P = (v\, V2, Vi), if Vi N(R) the choices for Vi + \ are the vertices in 
N(vi) \ N[{vi,V2, Vi-i}]. If Vi G N(R) then we have a leaf in the tree T 
of all possible choices. Thus, in the rooted tree T of all possible choices, 
if we label the nodes of T with the vertex chosen, the set of paths from 
the root to a leaf in T will be in 1-1 correspondence with the set of paths 
satisfying the statement in the Lemma without any bound on branch 
depth. 

Consider such a path P = (vi, V2, v q ). By definition the branch 
depth of P is b(P) = \N[{v\,V2, ...,v q -i}] \ — 1. Consider the leaf-to-root 
path Pt in T corresponding to P. For any 1 < i < q — 1 the children of 
the node in Pt labelled V{ have labels N(vi)\N[{v\,V2, and the 
node labelled v q is a leaf. Thus the children of all nodes of Pt have distinct 
labels and the union of all these labels is N[{vi, v%, \ {f i}- Thus 
the sum of the number of children over all nodes on Pt is exactly b(P). 

Consider any rooted tree T having the property that for any root-to- 
leaf path the sum of the number of children of all nodes on this path is at 
most t. Lemma [l] bounds the number of leaves in such a tree to l(t). By 
the above observations, and the fact that l(t) < 3 t//3 since 2 < 3 2 / 3 and 
4 < 3 4 / 3 , this proves the Lemma. 

This enumeration algorithm is optimal to within polynomial factors, 
see Figure 1. 

4 Enumeration of Minimal T-Connecting Sets 

Theorem [l] with \R\ = 1 can be viewed as an enumeration of all minimal 
T-connecting sets when T = {u,v}. We now generalize this approach 
to an arbitrary terminal set T by a branching algorithm. The following 
observation will be used to simplify our branching algorithm. 

Lemma 3. Given G = (V,E), T C V, and two vertices u,v G T such 
that uv G E. Let G' be the graph obtained by contracting edge uv into v. 
Then there is a one to one mapping between Minimal T -Connecting Sets 
in G and Minimal T \ {u} -Connecting Sets in G' . 

Proof. For every Minimal T-Connecting Set S in G we can contract edge 
uv and obtain a minimal T \ {u}-Connecting Sets S' = S \ {u} in G' . 



For every minimal T \ {u}-Connecting Sets S' in G 1 we can observe that 
G[S' U {u}] is a T-Connecting Set in G and it is also minimal as u £ T. 

Consider Algorithm Main Enumeration. It will solve Enumera- 
tion of Minimal T-Connecting Sets for any graph G = (V,E) and 
T Q V. Let us first give the informal intuition for the algorithm. We fix 
a vertex u £ T and using the algorithm of Lemma [2] we find all induced 
paths from u to N(T \ {u}). For each of these paths P we again call the 
algorithm of Lemma [2j but now on the graph G' where the path P to- 
gether with the vertices of T that P has in its neighborhood, is contracted 
into u. The path we find in G 1 will in G start at some vertex of P or a 
neighbor in T and we see that we start forming a tree of paths. We carry 
on recursively in this way until the collection of paths spans all of T, note 
however that the vertices of these paths may induce a graph containing 
cycles. To avoid repeating work we label vertices by a total order and use 
this ordering to guide the recursive calls. 

Lemma 4. Given G = (V,E), T C V and \T\ < n/3 Algorithm Main 
Enumeration will: 

1. output every Minimal T-Connecting Set of G, 

2. output, for any integer r £ [0..|V \ T\], at most (j^^J) • 3 r / 3 vertex 
sets S D T such that \N[S] \ T\ < r, and 

3. runinO*(QT\) .3^1/3) Ume 

Proof. 1.) Let us first argue that every Minimal T-connecting vertex set 
is output by the algorithm. In the case where \T\ < 1 the single vertex 
set T is output by the algorithm. In the remaining cases |T| > 1. 

Let S be a minimal T-connecting vertex set. Our goal will be to show 
that there will be a call MCS(C, X) performed by the algorithm in which 
T U C = S. Initially C = X = so we trivially have T U C C S and 
X n S = 0. Consider a call MCS(C, X) where we have \T U C| maximized 
under the constraint TuC C 5 and SC\X = 0. We show by contradiction 
that TuC = S for this call MCS(C, X). Assume, by sake of contradiction, 
that there is a terminal vertex not in C u , i.e. not in the component of 
G[T U C] containing u, i.e. that T' ^ 0. Let Vi be the lowest numbered 
vertex of (N(C u )nS)\ X. As S is minimal we have that G[S] is connected 
but G[S \ {i>2}] is not connected. By the minimality of S we have that 
G'[S'] is connected but G'[S'\{v2}] is not connected for S' = (S\C u )U{u} . 
Vertex v 2 is not a vertex of C U T and as S is minimal we have that each 
connected component of G'[S' \ {1*2}] contains a vertex of T'. If this was 



Algorithm Main Enumeration 

Input: A graph G = (V, E) and terminal set T C V 

Output: A family of sets containing all Minimal T-Connecting Sets 

begin 

assign each vertex a unique label between 1 and \V\ 
choose m6T 
MCS(0,0) 
end 

Procedure MCS(C,X) 

Parameter C: vertex set used to connect T 

Parameter X: vertices not to explore in this call 

begin 

if G[T U C] is connected then output TUC 
else 

set C u D C as vertex set of connected component of G[T U C] containing u 
set T' = T\C U i.e. the terminals not yet connected to u by C 
set G' to be graph obtained from G by contracting edges of G[C U ] to u 
call the algorithm of Lemma [2] on G'[V(G') \ X] with v% = u and R = T 
for every path P = (v\, v 2 , . . . , v q ) output by that call 

MCS(C U {v 2 , v g }, X U {w 6 N(C U ) : label(w) < label{v 2 )}) 
end-for 
end 



not the case, this component could simply be removed from S without 
changing the connectivity between vertices of T. Let B be a connected 
component of G'[S' \ {v 2 }] not containing u. By the previous arguments 
B contains a vertex of T' . Therefore the call of the algorithm in Lemma 
[2] on graph G' with R = T' will find a path P = (u, v 2 , ■ ■ ■ , v q ) with all 
vertices in S and with v q a neighbor of a vertex of T' in B and containing 
only vertex v 2 from N(C U ). This would lead to a recursive call where 
C would be updated to C U {v 2 , . . . ,v q } C S, and to X there would 
not be added any vertices of S as v 2 had lowest label among all vertices 
in (N(C U ) fl S) \ X, contradicting the maximality of \T U C\ under the 
constraint T U C C 5 and 5 n X = 0. 

2.) We bound the number of recursive calls in the algorithm and thus 
also the number of vertex sets that is output. Our objective will be to 
prove that the number of recursive calls MCS(C, X) where r = |JV[C W ]\!T| 
and p is the number of times a path is added to C, is at most (' X ]_^ p ) • 3 r / 3 . 



Note that p is equal to the depth of the recursion. Let x = \X\. As 
X C N(C U ) by the construction of the algorithm, p < \T\ — 1, and at 
least one vertex is added to C for each found path so p < |C|, we have 
that x+p < \N[C U )\T\ = r. Given that \T\ < n/3 and thus \ V\T\ > 2\T\ 
it is clear that (jyj^) > (p-i) an< ^ the claim of the lemma follows. 

The proof will be by induction on I = x + p. We assume without 
loss of generality that \T\ > 2. The first call is MCS(0,0) in which case 
p = 0, and this is in fact the only call where x + p < 0. The execution 
of MCS(0,0) will call the algorithm of Lemma [2] on G' with v\ = u and 
R = T' and make a recursive call MCS(C, X) for each path P output by 
the algorithm of Lemma [2] Consider such a call MCS(C, X) originating 
from path P. This call will have x = \X\ > 0, p = 1, and it will have 
r = \N[C U ] \ T\ > b(P). The number of paths P with b(P) < r output by 
the algorithm of Lemma [2] applied to the execution of MCS(0,0) on G 
with vi = u and R = T' is at most 3 r / 3 . Since 3 r / 3 < g+f) • 3 r / 3 for p = 1 
we have just established the base case t = x + p < 1 this also covers all 
cases where p < 1 in our induction. 

In the induction step we consider the case where £ = x + p > 2 and 
p > 1. Let MCS(C",X') be a call and let x' = \X'\, r' = \N[C' U ] \ T\, 
and p' be the number of paths added, or equivalently the depth of the 
recursion. By the induction hypothesis we assume that the bound holds 
for the number of calls MCS(C", X') where x' + p' < x + p — 1. 

Every call MCS(C, X) where x+p = £is created by a call MCS(C", X') 
and a path P = (v±, V2, ■ ■ ■ , v q ) such that C = C'u{v2, ■ ■ ■ , v q }, p' = p — 1, 
and X = X' U {w G N(C' U ) : label{w) < label(v2)} ■ As each vertex from 
N(C' U )\X' chosen as V2 will create a unique size of the set X = X'L){w G 
N(C' U ) : label(w) < labelfa)} for the next recursive call there is at most 
one choice for V2 starting from a fixed MCS(C", X') when it should lead to 
a recursive call MCS(C, X) where x + p = t. However, there are choices 
for the sub-path vertices (V3, . . . ,v q ), but these vertices can be chosen 
only among V \ (N[C' U ] U T), since V2 is fixed in N(C' U ) and the path 
P is induced. Note that any such sub-path has branch-depth at most 
|A^[C U ] \ (Af[C(J U T)\. We can use Lemma [2] to bound the number of 
such sub-paths, as follows. By applying Lemma [2] to the graph we get 
from G[V \ (N(C' U ) \ {^2})] by contracting C' u U {^2} to u = v\ and with 

R = T \ C' u we deduce that the number of such sub-paths is at most 

3 (\N[Gu]\(N[C'JjT)\)/3 m 

This means that the number of calls MCS(C, X) where x + p = £ 
is at most the number of calls MCS(C",X') where G C C, X' C X 
thus x' < x, and p 1 = p — 1, times 3^ N ^- Cu ^ ( - N ^ c '^ uT ^^ 3 . By the induction 



hypothesis we have that the number of calls MCS(C", X') where x'+p' < I 

is at most ( x p ^fZi) ■ 3^ N ^- c ' u ^ T ^ 3 . Multiplying these two factors we get 

• 3 lN[CLm/3 ■ 3(\N[Cu]\(N[Ci]uT)\)/3 which can be simplified to 

p'+(p-l)\ _ o(|JV[O u ]\T|)/3 
\(p-l)-l) 6 

Thus it remains to bound the number of calls MCS(C",X / ) that can 
make a new recursive call MCS(C, X) where x + p = £ to be at most 
glf). We know that each call MCS(C",X') can only make calls where 
x + p = I when it uses the unique vertex v 2 £ N(C' U ) \ X as the second 
vertex of the path. Thus it suffices to count these calls, and let y be the 
number of such calls. We have that 

i+p- 1\ o(\N[C u ]\T\)/3 
P-1-1 3 

Using the standard observation that Y^=o ( m ) = (m+l) we can con " 
elude that y < g+f) • 3^ N[Cu] \ T ^ /3 and the proof is completed. 

3.) In the previous claim we bounded the number of recursive calls in 
the algorithm to (jjj^j) • 3 r / 3 vertex sets S D T such that |JV[fi] \ T| < r 
and |T| < n/3, and as Lemma [2] ensures that all paths in a single call can 
be enumerated within a polynomial delay it follows that the polynomial 
bound holds. 

Using Lemma [4] we can make the following conclusion. 

Theorem 2. For an n vertex graph G = (V, E) and a terminal set Tcy 
where \T\ < n/3 there is at most ■3^ n ~^^ 3 minimal T -connecting 

vertex sets and these can be enumerated in 0*((]£j!3) ' 3(™-l T D/ 3 ) time. 

5 The 2-Disjoint Connected Subgraphs problem 

Let us now use Theorem [2] to solve the 2-Disjoint Connected Subgraphs 
problem. Recall that the problem is defined as follows: 

2-Disjoint Connected Subgraphs 

Input: A connected graph G = (V, E) and two disjoint subsets of 
vertices Z\, Zi C V. 

Question: Does there exist two disjoint subsets A\, A2 of V, with 
Z\ C A 1 , Z 2 C A 2 and G[^ 2 ] both connected? 




Theorem 3. There exists a polynomial space algorithm that solves the 
2-Disjoint Connected Subgraphs problem in O* (1.7804™) time. 



Proof. Let us assume without loss of generality that \Zi\ < \Z 2 \ and let 
a = \Z\\/n; note that < a < 0.5. The algorithm has a first stage that 
finds a list of potential candidates for A\ and a second stage that checks 
each candidate to see if it can be used as a solution. In the first stage 
we choose between two different strategies depending on whether or not 
a > 0.0839. 

Consider first the case where a < 0.0839. Vertices of Z 2 are of no 
use when searching for a potential set A\ so it suffices to consider the 
graph G[V \ Z 2 ]. By the algorithm for Enumeration of Minimal T- 
Connecting Sets of Theorem [2] we know that for \Z%\ < n/3 in the 
graph G[V \ Z 2 \ all minimal Zi-connecting sets can be enumerated in 



^((""iZitf 2 ') • 3(™-l Zl H Z2 IV 3 ) time. As \Z X \ < \Z 2 \ it is clear that 



an < \Z 2 \. The number | Z 2 | only contributes negatively so we can observe 
that 



where f3 = (1 — 2a). It is not hard to verify that the maximum value of 
/(i-2o)rA . 3 (i- 2a )n/3 f or o < a < 0.0839 occurs when a = 0.0839 and that 

\ an— 2 / — 

/(i-2«)rA . 3 (i_ 2a )n/3 < L780 4™ for a = 0.0839. Thus, we can conclude 

\ an— 2 / — 

that when a < 0.0839 a list of all minimal Zi-connecting sets can be 
found in time 0*( 1.7804"). 

Consider now the case where a > 0.0839. In this case the algorithm 
simply loops over all subsets of V \ {Z\ U Z2) to list every vertex subset 
A C (V \ Z 2 ) where Z\ C A. As a > 0.078 and an = \Z X \ < \Z 2 \ we get 
that the number of such subsets is at most 2 n ~ 2a < 1.7804 n and they can 
be found in O* (1.7804™) time. 

For the second stage of the algorithm, for every listed set A, the 
algorithm tests if vertices of Z2 are contained in the same connected 
component of G \ A and if so the algorithm returns the solution with 
A\ = A and A 2 being the vertices of the connected component of G \ A 
containing Z 2 . This is clearly a solution to the problem. Conversely, if 
there is a solution A\, A2 to the problem, then there is clearly one where 
A\ is a minimal Zi-connecting set. 

Finally, observe that the algorithm uses polynomial space as a simple 
branching algorithm is used for both cases. 




By using the Stirling approximation we know that (^^-2) ls O*{( 



Conclusion 



The graph in Figure 1 shows that our algorithm for Enumeration of 
Minimal T-Connecting Sets given by Theorem [2] is optimal, up to 
polynomial factors, for the case \T\ = 2. Is the algorithm optimal, up to 
polynomial factors, also for larger T, let us say \T\ < O.ln? 

Let us remark that our algorithm for Enumeration of Minimal 

/IV\TI\ \ V \ T \ 

T-Connecting Sets can be used to give a 

°*((|T|-2) - 3 ~) algorithm 
for Steiner Tree with unit weights on terminal vertices T. This is 
upper bounded by 0*(1.8778 n ) when balanced with the standard brute 
force search, but will not beat the fastest algorithm for this problem, 
which is by Nederlof [9j and has runtime O* (1.3533™) using polynomial 
space. 

The algorithm given in this paper for Enumeration of Minimal 
T-Connecting Sets may have more applications in the future, apart 
from 2-Disjoint Connected Subgraphs, in particular for problems 
where the enumeration of all solutions is required. 
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